草庐IT

javascript - 匹配行尾 javascript 正则表达式

全部标签

ruby - 正则表达式,如何匹配多行?

我正在尝试将From行一直匹配到Subject行的末尾,如下所示:....From:XXXXXXDate:Tue,8Mar201110:52:42-0800To:XXXXXXXSubject:XXXXXXX....到目前为止我有:/From:.*Date:.*To:.*Subject/m但这与主题行的末尾不匹配。我尝试添加$但没有效果。 最佳答案 您可以使用/m修饰符启用多行模式(即允许.匹配换行符),您可以使用?执行非贪婪匹配:message="From:person@example.com\nDate:01-01-2011\nT

ruby - 查找与给定条件匹配的元素的索引

给定一个数组,如何找到符合给定条件的元素的所有索引?例如,如果我有:arr=['x','o','x','.','.','o','x']要找到项目为x的所有索引,我可以这样做:arr.each_with_index.map{|a,i|a=='x'?i:nil}.compact#=>[0,2,6]或(0..arr.size-1).select{|i|arr[i]=='x'}#=>[0,2,6]有没有更好的方法来实现这一目标? 最佳答案 ruby1.9:arr=['x','o','x','.','.','o','x']parr.each_

ruby - 将 Ruby 正则表达式拆分为多行

这可能不是您所期待的问题!我不想要一个匹配换行符的正则表达式;相反,我想写一个很长的正则表达式,为了可读性,我想分成多行代码。类似于:"bar"=~/(foo|bar)/#Doesn'twork!#=>nil.Wouldlike=>0可以吗? 最佳答案 将%r与x选项一起使用是执行此操作的首选方法。请参阅githubruby​​样式指南中的示例regexp=%r{start#sometext\s#whitespacechar(group)#firstgroup(?:alt1|alt2)#somealternationend}xreg

ruby - 为什么表达式 (true == true == true) 会产生语法错误?

ruby:true==true==truesyntaxerror,unexpectedtEQ对比JavaScript:true==true==true//=>true对比C:1==1==1//=>1 最佳答案 关联方向控制运算符对其参数求值的顺序,未为==定义。方法,与===相同,!=,=~和方法也是如此(所有方法都具有相同的优先级,并且专门形成一个单独的优先级组)。Documentation因此,如果上述列表中的多个运算符被链接成一行,则应通过任一方式显式设置评估顺序括号():(true==true)==true#=>truetr

ruby - 检查字符串是否与 ruby​​ 中的正则表达式匹配的最快方法?

检查字符串是否与Ruby中的正则表达式匹配的最快方法是什么?我的问题是我必须“egrep”一个巨大的字符串列表以找到哪些匹配运行时给定的正则表达式。我只关心字符串是否匹配正则表达式,不关心匹配到哪里,也不关心匹配组的内容是什么。我希望这个假设可以用来减少我的代码花在匹配上的时间正则表达式。我加载正则表达式pattern=Regexp.new(ptx).freeze我发现string=~pattern比string.match(pattern)稍快。是否有其他技巧或快捷方式可用于使此测试更快? 最佳答案 从Ruby2.4.0开始,您可

ruby - Ruby 正则表达式是否有像 Perl 中的 "!~"这样的不匹配运算符?

我只想知道ruby​​正则表达式是否有不匹配运算符,就像!~一样在perl中。感觉用起来不方便(?!xxx)或(?因为你不能在xxx中使用正则表达式模式部分。 最佳答案 是的:!~工作得很好——你可能认为它不会因为it’smissingfromthedocumentationpageofRegexp.尽管如此,它还是有效的:irb(main):001:0>'x'!~/x/=>falseirb(main):002:0>'x'!~/y/=>true 关于ruby-Ruby正则表达式是否有像P

ruby - 如何使用正则表达式和反向引用编写 Ruby switch 语句(case...when)?

我知道我可以编写Rubycase语句来检查与正则表达式的匹配。但是,我想在返回语句中使用匹配数据。像这样的半伪代码:foo="10/10/2011"casefoowhen/^([0-9][0-9])/print"themonthis#{match[1]}"elseprint"somethingelse"end我怎样才能做到这一点?谢谢!请注意:我知道我永远不会在上述简单情况下使用switch语句,但这只是一个示例。实际上,我试图实现的是为一个可以用各种方式编写的日期匹配许多潜在的正则表达式,然后相应地使用Ruby的Date类对其进行解析。 最佳答案

ruby-on-rails - RoR 4 中带验证的正则表达式

有如下代码:classProduct它有效,但是当我尝试使用“raketest”对其进行测试时,我会收到此消息:rakeaborted!Theprovidedregularexpressionisusingmultilineanchors(^or$),whichmaypresentasecurityrisk.Didyoumeantouse\Aand\z,orforgottoaddthe:multiline=>trueoption?这是什么意思?我该如何解决? 最佳答案 ^和$是StartofLine和EndofLineanchor。

ruby - 返回 Ruby 正则表达式的第一个匹配项

我正在寻找一种在Ruby中对字符串执行正则表达式匹配并使其在第一个匹配项时短路的方法。我正在处理的字符串很长,从标准方式(match方法)来看,它会处理整个字符串,收集每个匹配项,并返回一个包含所有匹配项的MatchData对象。match=string.match(/regex/)[0].to_s 最佳答案 你可以试试String#[](如variableName[/regularexpression/])。这是IRB的示例输出:names="erikkallejohananderserikkallejohananders"#=>

ruby - 如何通过匹配 Capybara 中元素的精确文本来查找元素

我在HTML中有以下两个元素BerlinBerlinGermany我正在尝试使用以下Capybara方法查找元素find("a",:text=>"berlin")上面将返回两个元素,因为它们都包含文本berlin。有没有办法在Capybara中精确匹配文本? 最佳答案 使用正则表达式而不是字符串作为:text键的值:find("a",:text=>/\ABerlin\z/)查看方法的“选项哈希”部分:Capybara::Node::Finders#alldocumentation.PS:文本匹配是区分大小写的。您的示例代码实际上引发